#pragma once
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>


typedef int HPDataType;
typedef struct Heap
{
	HPDataType* a;
	int size;
	int capacity;
}HP;


void HeapInit(HP* php);

void HeapInitArry(HP* php, int* a, int n);

void HeapPush(HP* php, HPDataType x);

void HeapPop(HP* php);

void HeapDestroy(HP* php);

void AdjustUp(HPDataType* a, int child);

void AdjustDown(HPDataType* a, int n, int parent);

HPDataType HeapTop(HP* php);

bool HeapEmpty(HP* php);

int HeapSize(HP* php);

void Swap(HPDataType* x1, HPDataType* x2);














